home *** CD-ROM | disk | FTP | other *** search
/ TPUG - Toronto PET Users Group / TPUG Users Group CD / TPUG Users Group CD.iso / AMIGA / (A)TB / (A)TBT.ADF / Virus_Checker5.36 / Virus_Checker.doc < prev    next >
Text File  |  1991-11-30  |  39KB  |  781 lines

  1. Virus Checker
  2. -------------
  3.    This Program
  4.  
  5. Virus_Checker is a freely distributable, copyrighted piece of software.
  6. You do not have to pay money to use it, and may upload it wherever you
  7. choose, but you are not allowed to sell Virus_Checker for profit, or
  8. include Virus_Checker on a disk which is sold for profit, without the
  9. author's (John Veldthuis) permission.
  10. Commodore have this permission already.
  11.  
  12. Money is not solicited but would be welcome.
  13. I can be contacted at the address below.
  14.  
  15. Please send me any more new viruses so I can update Virus_Checker
  16.  
  17. But please don't send a letter asking for a copy without sending me at
  18. least a disk to send it back on. I just cannot afford to do this.
  19.  
  20. John Veldthuis
  21. 21 Ngatai Street
  22. Manaia, Taranaki
  23. New Zealand
  24. Phone  (0624) 8409
  25.  
  26. Email addresses:
  27. FIDO 3:771/400.0
  28. USENET johnv@tower.actrix.gen.nz
  29.  
  30.  
  31. I have been asked to include the following:
  32.  
  33. Virus_Checker can be kept up to date thanks to the energy and work put into
  34. a global anti-virus information bank founded by Erik L°vendahl S°rensen
  35. from Denmark.
  36.  
  37.   This group has over 120 international members now, among them some of the
  38. programmers of well known anti-virus programs like Steve Tibbet and Jonathan
  39. Potter.  Among the activities of this group are:
  40.  
  41. - Spreading information to anti-virus programmers as fast as
  42.   possible.
  43. - Trying to get names and proof against virus programmers and
  44.   giving the information to the justice department of his/her
  45.   country to press charges.
  46. - Writing articles in popular magazines to inform new Amiga
  47.   users about viruses and how to protect themselves.
  48.  
  49.   All this is volunteer work.  If you want some more information about this
  50. organization or you want to sponsor our work, contact Erik at the following
  51. address:
  52.  
  53.    Erik L°vendahl S°rensen
  54.    Snaphanevej 10
  55.    4720 Prµst°
  56.    Denmark - Europe
  57.  
  58.    Phone: 00 45 53 79 25 12
  59.    Fidonet 2:230/114.26
  60.  
  61. To use Virus_Checker , place in your startup-sequence the following line -
  62.  
  63. Virus_Checker
  64.  
  65. This will run virus_checker.
  66.  
  67. Or from the CLI Type Virus_Checker and hit return.
  68.  
  69.  
  70. ****** Special Notice for Users of File Packers and Crunchers ******
  71.  
  72. If you use a program such as PowerPacker to make your files smaller then be
  73. aware to check these files before you crunch them. If the file is infected
  74. and you crunch them then VC will not find the virus in the file and each
  75. time you use that file it will infect your machine.
  76. VC will still detect the virus in memory and remove it okay.
  77. So if you get VC telling you your memory is infected but you cannot find it
  78. on any disks then start unpacking any of these files and check them
  79. UNPACKED.
  80.  
  81. **New features**
  82. ----------------
  83. New Features added to Virus_Checker are added to the command line.
  84. The syntax is Virus_Checker -l### -t### -w### -b -q -n dirname
  85. where ### is any decimal number
  86.  
  87. -l### Tells Virus_Checker  how far from the left edge of the screen to open
  88.       the Virus_Checker window.
  89. -t### Tells Virus_Checker how far down from the top edge of the screen to
  90.       open the Virus_Checker window.
  91. -w### Tells Virus_Checker how wide you want the window. It has a maximum
  92.       size of 386 pixels and a minimum of 200. Any numbers out of this
  93.       range are ignored.
  94. -b    Tells Virus_Checker to send its window to the back of all the other
  95.       open windows.
  96. -n    Tells Virus_Checker not to open a window. It will check memory and
  97.       disks inserted but you will have to use the ARexx port to get it to
  98.       scan the whole disk for Link/File viruses.
  99.       To stop VC, run VC again or use the ARexx port.
  100.       Versions prior to 5.33 opened a 1x1 bit backdrop window but 5.33 on
  101.       do not open any window except requester windows when needed.
  102. -q    Virus_Checker will check all memory, files, and disks for viruses
  103.       then exit. To check the dh0: partition and exit do the following -
  104.       Virus_Checker -q dh0:
  105.       This will check memory, disks, files, and dh0:, then exit.
  106.  
  107. dirname is the directory/file you want checked for File Viruses on startup.
  108.     An example to open the window at x/y position of 200/100 and check DH0:
  109.     is Virus_Checker -l200 -t100 dh0:
  110.  
  111. Any values outside the size of the WB screen are ignored and any non
  112. numerical values are ignored. There must be no spaces between the options
  113. and the numbers. Options may be given in any order.
  114.  
  115. ***  AREXX PORT added ***
  116. -------------------------
  117. An Arexx port has been added to VC so you can make VC do things from an
  118. ARexx script. The port name is  Virus_Checker. Be aware that case is
  119. important and ARexx will not find it if the name is not spelt right.
  120. Here is an example
  121. address 'Virus_Checker'    /* Talk to Virus_Checker  */
  122. 'checkdrive\df0:'          /* Make virus_Checker check df0: for viruses */
  123. 'scanforsaddam\df0:'       /* Make VC check df0: for Saddam virus damage 
  124. 'quit'                     /* Make Virus_Checker shut down */
  125.  
  126. Notice the '\' between the command and the drive name in the middle
  127. examples. This must be put between all commands and their options. 'quit'
  128. does not take an option so does not need the '\' character there.
  129. Virus_Checker will take the following commands
  130.  
  131. checkdrive\drivename      Check drive drivename for file viruses.
  132. scanforsaddam\drivename   Check drive (DF0:-DF3) for Saddam damage.
  133. quit                      Make Virus_Checker shut down.
  134.  
  135. None of the ARexx commands returns results to Arexx.
  136.  
  137.  
  138. As from Version 5.27
  139. --------------------
  140. If Virus_Checker is already running and you give it a blank command line
  141. then it will ask you if you want to stop Virus_Checker. If you give it a
  142. directory/File name then it will be passed on to the running Checker and
  143. the scan will start straight away.
  144. If you select the VC window and press the s key this will bring up the disk
  145. scan requester (same as right mouse button) and if you press the m key, VC
  146. will do another complete memory scan.
  147.  
  148. Upon running Virus_Checker will first check your memory for viruses and
  149. tell you if any were detected. They will either be removed or disabled. Next
  150. all disks in the drives will be checked. Any disk put into any drive
  151. (df0: to df3:) will be checked. The rest is easy.
  152. Sometimes the machine may GURU when it disables the LAMER Exterminator virus
  153. in memory but if you reboot it should be gone.
  154.  
  155. Keys Active when Virus_Checker window is active
  156. -----------------------------------------------
  157. The Following keys will activate the following functions
  158.  
  159. s -    Will activate the Scan mode (Same as right mouse button)
  160. m -    Will immediately do a complete memory scan (same as startup)
  161. f -    Will activate the Saddam Disk Scan (used to fix Saddam virus damage)
  162. 0 - 3  Will check the First File in startup-sequence and bootblock on disk
  163.        in drive which matches number
  164.  
  165.  
  166. Link/File virus check
  167. ---------------------
  168. If you want to check a disk for Link/File viruses then put the disk in
  169. any drive. Make sure the Virus_Checker window is active the press and
  170. release the right mouse button (or press s key).
  171. This will bring up a requester asking you which drive to check.  Enter the
  172. drive name in the box, eg.  DF0:, DH1:,RAD:  etc.  It will then check all
  173. the files on that drive.  You can also enter directories if you want to eg,
  174. c:  df0:c, df0:libs etc
  175. When Virus_Checker is scanning the disk and you know that a directory is
  176. clear and don't want to check it press control-d in the window with the
  177. filenames and Virus_Checker will ignore that directory and go back up one
  178. level.
  179. If you want to stop the check completely press control-c in the window with
  180. the filenames and Virus_Checker will print a break message then stop
  181. scanning the disk and go back to normal scanning.
  182.  
  183. If Virus_Checker brings a requester up that says a program just run has
  184. infected your memory with the Xeno Virus, it has already disabled it.
  185. You should immediately check all files on the disks that are in the drives
  186. at that time. This means that a program that you just ran or a program
  187. some other program just ran is infected with the virus and all files
  188. should be checked to find out which one it was.
  189.  
  190. With viruses which use a RomTag I have decided to clear out all RomTags to
  191. make sure I remove the Viruses from the list. In doing this you will lose
  192. things like Recoverable ram disks such as RAD:, VD0: etc. If you have a
  193. virus make sure that you save anything in the ram disks that you want
  194. before rebooting. The ramdisks and others will disappear on a reboot.
  195. My policy is better safe than sorry.
  196.  
  197. BRAINFILE ADDITION
  198. ------------------
  199. I have added a BrainFile to Virus_Checker as of Version 5.13. When VC finds
  200. a Non-Standard bootblock it will bring up 4 gadgets. The new Gadget is Learn.
  201. Pressing this will allow VC to remember this BootBlock and not bother you
  202. again with it.
  203. To do this VC writes a file called VCBrainFile to the S: directory.
  204. If you have a single drive this will invoke a requester asking that Volume
  205. something be put in the drive. This will then save to the file.
  206. On Startup VC will check for the file in the S: directory and read it if it
  207. is there. If not it will carry on without it. If you get an error then VC
  208. will tell you about it and will happily write over the file next time.
  209.  
  210.  
  211. Versions
  212. --------
  213. V1.0  Was an arp.library version.
  214. V1.1  Was an port to the normal libraries.
  215. V1.2  Had the ByteBandit virus detection added into it.
  216. V1.3  Had detection of the 3 Viruses in memory and removal of them.
  217. V1.4  Added code to detect + remove the Byte Warrior Virus from memory
  218.       and disk.
  219. V1.41 Found a slight bug when using DSM to disassemble this.
  220.       The program was testing low memory instead of a value when
  221.       checking for the Revenge Virus.
  222. V1.42 Changed code to be assembled by the CAPE 68K assembler.
  223.       which is much faster than A68k or Assem. Now also uses base register
  224.       addressing mode for data access.
  225. V1.43 Changed code to cut down executable code.
  226. V2.0  Added Pentagon, System Z, North Star, Obelisk and the
  227.       new IRQ virus which lives in files and not in the Boot Block.
  228. V2.1  Corrected a few little bugs in program.
  229. V3.0  Did a listing of Source code and found many bugs.
  230.       Did a major rewrite to clean it up and saved about 400 bytes.
  231. V3.0  Now checks for these viruses -
  232.       SCA, AEK, Byte Bandit, Byte Warrior, Revenge, Pentagon Circle
  233.       System Z, North Star, Obelisk, Disk-Doktors and the latest IBM
  234.       type virus the IRQ virus.
  235. V3.01 Got a new virus, Lamer Exterminator. Added code to get rid of it.
  236. V3.02 Got a second version of the Lamer Exterminator virus.
  237. V3.03 After many requests decided to add checking of BootGirl
  238.       BootBlocks which were being registered as Non-Standard. It now
  239.       just ignores BootGirl BootBlocks.
  240. V4.00 Updated to make better use of the Stack. Now store all variables
  241.       on the stack for a saving of 124 bytes in the executable.
  242. V4.10 TimeBomb virus added to code.
  243. V4.20 Altered startup code to start a separate process to avoid doing
  244.       a RunBack -2 Virus_Checker.
  245. V4.22 Added Gadaffi virus to checker.
  246. V4.23 Found a potentially Fatal Error in Code when accessing Unit
  247.       Byte off the Stack.
  248. V4.24 Added Graffiti, Ultra Fox, and Phantasmumble Viruses.
  249.       Don't actually have these last 3 viruses so anyone please send them
  250.       to me if you find them. Still looking for the IRQ Virus as well.
  251. V4.25 Added BSG9 virus to code.
  252. V4.26 Changed Error Checking on BSG9 virus a bit.
  253. V4.27 Got the War Hawks virus and added it. Also added V3 of Lamer
  254.       Exterminator virus. Changed checking for BSG9 virus. Now checks
  255.       when disk is inserted into drive.
  256. V4.28 Found I was losing the memory that was used by the program when
  257.       it exited. This was caused by me not UnLoading the Segment used for
  258.       the program. Fixed.
  259. V4.29 Found program got into a continuous loop when there where no RomTags
  260.       present in the system. Fixed.
  261.       Also cut code size down a bit more by combining a few checks.
  262. V4.30 Put further checking in for the BSG9 virus as sometimes the checker
  263.       would not find the file on the disk depending on which directory
  264.       it was in. Put VKill virus checking in.
  265.       Also Ultra Fox and PVLProtector virus checking added.
  266. V4.40 Put in DosSpeed virus and an Unknown virus.It does not have any names
  267.       at all.
  268. V4.41 Stopped Requester that comes up after pulling disk out.
  269. V4.42 Added JITR virus which was sent to me by Jonathan Potter (AUST).
  270. V4.43 Added MicroSystems virus checking to code and BootBlock checking of
  271.       the HCS II, Opapa, BackFlash, and Australian Parasite viruses.
  272. V4.44 Changed code around a bit to get better use of tables and added
  273.       Xeno virus check for Memory only.
  274. V5.00 Changed user interface to give a new look and better messages.
  275. V5.01 Major Bug repaired. V5.00 GURU'ed when checking disk. Worked with
  276.       68020 CPU but failed on standard Amigas due to a bad address.
  277. V5.02 Was not checking startup-sequence properly when disk was put in 
  278.       3 1/2" drive when a filename was given as C:SetCPU or something like
  279.       that. Came up with a strange filename not being checked. Fixed.
  280.       Added second version of Byte Bandit Virus, Someone hacked it.
  281.       Added code to remove Xeno virus from files.
  282. V5.03 Slight bug corrected in code.
  283. V5.04 Have changed this from PD to Freely Redistributable after an offer
  284.       from someone to sell Virus_Checker. I feel this still needs to be
  285.       at minimal (copying charge) or no charge to be effective.
  286.       Also cleaned up the code a bit. This may introduce new bugs so
  287.       please tell me about them if you find them
  288.       Added checking of IRQ virus when checking for Xeno files on disk.
  289.       As the file is in the buffer already this adds very little extra
  290.       time to the check. And better safe than sorry.
  291. V5.05 Changed text when Xeno Virus found after a program has been run
  292.       to warn that the program just run may be the culprit.
  293. V5.06 Added 16 Bit crew Virus, New Alien Beat Virus, Digital Emotions
  294.       virus, Graffiti Virus, two new versions of the Byte Bandit virus,
  295.       ScarFace virus, Turk virus, Joshua virus.
  296.       Also a little bug when used with NTSC machines. You could not display
  297.       the Boot Block Sectors. Now Startup alters for which machine it is
  298.       on. The Startup code is only used once and then the memory for it
  299.       is freed.
  300. V5.07 Added better Error messages when an error occurs with files.
  301.       It will now say File protected from deletion when the file is
  302.       protected instead of just saying could not open file.
  303.       Added Butonic virus to checker.
  304. V5.08 Added Centurions virus to checker.
  305. V5.09 Got Aids virus but this is a mutant VKill virus and is found already.
  306.       Added Coders nightmare virus to checker.
  307.       Added Forpib, GX Team, Gremlins, and Kauki Virus.
  308.       Added Centurions and Butonic virus check when scanning disk.
  309. V5.10 Finally got IRQ virus and corrected a few bugs in its code.
  310.       Added Target, Clist, Abraham, and FAST virus. This FAST virus is
  311.       supposed to be from the Federation Against Software Theft. If it is,
  312.       then they are just as big arseholes as the pirates themselves.
  313.       Added Tick virus.
  314.       Added control-c, control-d to multiscan pass so as to stop the scan
  315.       if you got the wrong directory or drive.
  316. V5.11 Slight bug in removing BSG9 virus if virus not in devs: directory.
  317.       Also was picking up some game files as Butonic virus.
  318. V5.12 Virus_Checker was finding WB2.0 reboot code as the HCS II virus.
  319.       This code may not be in the final release but it is at the moment.
  320.       Also SetPatch code moved a bit. Seems to be the same but different.
  321. V5.13 Added a Brain File so that you can remember the BootBlocks that
  322.       You want to. Games etc.
  323.       No new viruses added.
  324. V5.14 Added a feature to allow checking for link viruses on startup
  325.       eg. virus_checker dh0: will check dh0: before carrying on as usual.
  326. V5.15 Slight bug found with brain file.
  327. V5.16 ULDV8 virus added. Uses VertB int and RomTag. Very Tame virus.
  328.       Also fixed up bugs when using Enforcer. Showed up some reads to
  329.       non-existent memory.
  330. 5.17 Added OP1 virus. Seemed to confuse VC into think it had a standard
  331.      Boot block unless write protected.
  332. 5.18 Had to add extra checking for IRQ virus as it found a program that
  333.      matched IRQ and VC crashed trying to remove the IRQ virus which
  334.      wasn't there.
  335. 5.19 Added a much asked for feature so that you can tell VC where to put
  336.      its window.
  337. 5.20 Added a width parameter as well. Also added 1 new virus called the
  338.      SADDAM virus. This virus lives as the Disk-Validator and can infect
  339.      an Amiga simply by putting a disk in the drive.
  340. 5.21 Added the CCCP virus to the checker.
  341. 5.22 Added another version of the Joshua virus. Also fixed bug that occurred
  342.      when checking for file viruses and a name was in the File Header.
  343.      Added -q option to make VC check and then quit.
  344. 5.23 Added ARexx port to Checker. Will Take commands via Arexx. See info
  345.      above.
  346.      Added Disaster Master Virus 2, another file type virus.
  347. 5.24 Added checking memory for Australian Parasite virus, added BootBlock
  348.      viruses:- BlowJob ,Butonic-Bahan, Byte Voyager I, Byte Voyager II,
  349.      Destructor, DiskGuard, Fast1, ByteWarrior FastLoader (not really a
  350.      virus), FICA, Mad II, Hilly, Changed OP1 virus to real name (Joshua),
  351.      Changed Tick virus to real name (Julie), Another version of Lamer
  352.      Exterminator, MegaMaster, Paradox, Saddam Hussein (Paradox copy),
  353.      Termigator, SuperBoy, UltraFox, Vermin viruses.
  354.      Another version of the BSG9 file virus was found so I changed the
  355.      checking to find both versions.
  356.      Added second version of Butonics File virus, added Hawnes file virus.
  357.      Added another version of the BSG9 virus and Return Lamer File virus.
  358.      Did a big rewrite of the checking for file viruses. Now reads file
  359.      once and scans a table of data. Will do the same with Link viruses
  360.      later.
  361. 5.25 VC was finding BootMenu as the Destructor virus. Changed scanning of
  362.      startup-sequence so disks with the cmd sys:c/command would have the
  363.      sys: stripped off them. VC could not find these before.
  364.      Fixed bug which sometimes screwed the virus name reported in the
  365.      requester. 1 BB virus added.
  366.      Changed name of DOSSPEED virus to its real name. Revenge Lamer Ext.
  367. 5.26 Fixed bug that was shown when disk in df1: had a startup-sequence
  368.      entry that said df0:filename. Tried to access df0: when no disk in
  369.      drive.
  370.      Added  Turk Virus file carrier. This was a file that carried to Boot
  371.      Block virus Turk.
  372.      Added a logic bomb file virus. This would wipe out a floppy after the
  373.      the file had been run so many times.
  374.      Added about 10 new BootBlock viruses.
  375. 5.30 Fixed bug that showed up as DF0:2has... and no learn gadget on display.
  376.      Added -n option to make VC window 1x1 pixel/backdrop effectively no
  377.      window.
  378.      Also added keys to VC. Press 's' key to start Disk Scan (same as right
  379.      mouse button), 'm' to do a memory check.
  380.      Added a Lamer TimeBomb Virus, EMWurm logic bomb, and another version
  381.      of the Travelling Jack virus.
  382. 5.31 Small problem with startup from Workbench corrected.
  383. 5.32 Fixes a major bug in the FixSaddam code. It Guru'ed under 68000
  384.      sometimes and never fixed the Checksums properly.
  385. 5.33 Released 6 November 1991.
  386.      WB2.0 BootBlock added to code.
  387.      True no window option added for those users of WB2.0.
  388.      Added liberator virus and fixed slight bug with Saddam virus,did not
  389.      reset TD BeginIo Close vectors.
  390. 5.34 Increased stack size to 4000 bytes as it was crashing when used with
  391.      PowerPacker Patcher.
  392.      Added Hackers Etic BB virus
  393.      Little problem with the CTRL-C and CTRL-D when used in FixSaddam mode
  394. 5.35 Released 21 November 1991
  395.      Added support for the asl.library FileRequester when running under WB2
  396.      When you select scan disk you can now select Use Requester gadget and
  397.      this will bring up the asl FileRequester
  398. 5.36 Released 23 November 1991
  399.      Added better handling of Proportional fonts. Requesters look much
  400.      better now
  401.  
  402. ************************************************************************
  403.  
  404. NON-STANDARD BOOT CODE
  405.  - When Virus_Checker brings up a Requester that says the disk has
  406. non-standard boot code this means that the code in the boot block is not
  407. what should be there. This does not mean that it is a virus as many games
  408. use copy protection in their boot blocks. You should however be cautious if
  409. it is not a game. Do not replace the boot block if you are not sure. If
  410. something strange happens then please send a copy of the disk to me so that
  411. I can check it out.
  412. Here is a way of checking non-standard boot code
  413.  
  414. 1.      Format a blank disk so you know it is clear.
  415. 3.      Make sure all disks except the one just formatted are write protected
  416. 3.      Boot from the disk that you suspect.
  417. 4.      Place formatted disk in drive zero and then reboot.
  418. 5.      Take disk out of drive zero and turn off computer for about 30 secs.
  419. 6.      Run the Virus_Checker program. If the Virus_Checker finds
  420.         non-standard boot code on the newly formatted disk you have found a
  421.         new virus. Please send it to me.
  422.  
  423.   Viruses Dealt With:
  424.   -------------------
  425.  
  426. SCA
  427.  - The SCA is the simplest virus to deal with, as it's not actually DOING
  428. anything except hiding in memory, until you reboot.  We just look at
  429. CoolCapture and fix it to get it out of RAM.
  430.  
  431. AEK
  432.  - This is a clone of the SCA virus and we get rid of it in the same
  433. manner.
  434.  
  435. LSD 
  436.  - Another SCA clone and uses the same code.
  437.  
  438. Byte Bandit  (Now 4 versions)
  439. (Amiga Freak)
  440.  - The Byte Bandit virus takes the DoIO() vector and re-directs it through
  441. itself.  Thus, any attempt to read or write the boot block (ie, AmigaDOS
  442. trying to figure out what kind of disk it is) results in the BB writing
  443. itself onto that disk.  We couldn't just rewrite the boot block, we have to
  444. get him out of RAM first.  This virus also has an interrupt that crashes the
  445. machine every 5 minutes or so after it's infected a few of your disks. Ow.
  446. It stays in memory not via the Capture vectors, but by a Resident module.
  447. When machine looks crashed press these keys at the same time from left to
  448. right LAlt,LAmiga,Space,RAmiga,RAlt.
  449.  This will restore things for another 5 minutes.
  450.  
  451. Revenge
  452.  - Basically, a Byte Bandit clone except it will bring up an obscene pointer
  453. a few minutes after you reboot.  We treat it much like the byte bandit.
  454.  
  455. Byte Warrior
  456.  - Jumps right into 1.2 Kickstart.  Won't work under 1.3.
  457.  Hangs around via Resident struct, doesn't do any damage.
  458.  
  459. North Star/ StarFire
  460.  - Like SCA, hangs around via CoolCapture, killing CoolCapture kills the
  461. North Star.
  462.  
  463. Obelisk Softworks Crew
  464.  - Hangs around via CoolCapture, also watches reads of DoIO() (but doesn't
  465. infect EVERY disk - only ones you boot from).
  466.  
  467. IRQ
  468.  - This is the FIRST Non-Bootblock Virus.  It copies itself from place to
  469. place via the first executable program found in your startup-sequence.  It
  470. SetFunction's OldOpenLibrary(), has a KickTagPtr, and lives in the first
  471.  hunk of an infected program.
  472.  
  473. Pentagon Circle
  474.  - This one looks at the DoIO vector, and has a CoolCapture vector. It will
  475. write itself over any virus inserted, but not onto anything else. No
  476. danger, easy to eliminate.  Holding left button while booting with this one
  477. shows different screen colour, but doesn't get rid of it.
  478.  
  479. HCS Virus
  480.  - Hooks into the System Z protector
  481.  
  482.  - This is another virus protector that can write itself to disks.  Anything
  483. that spreads itself, under any name, is a virus.  Doesn't do anything except
  484. during a reboot, then examines disks and writes over viruses.
  485.  
  486. Disk-Doktors
  487.  - This is another virus which looks at the DoIO routine for the reading of
  488. any bootblocks.  If it finds one it will rewrite a copy of its code to it if
  489. it can.  This one also patches into the Vertical Blank interrupt and seems
  490. to format your disk after a certain number of interrupts (can't be sure
  491. though).The nasty bit is it also creates a task called clipboard.device
  492. which spends its life copying itself through memory fragmenting the memory
  493. into small blocks.  Calls ROM CODE direct so won't work under V1.3.  We
  494. restore the DoIO routine, the Vert Blank interrupt and RemTask the
  495. clipboard.device
  496.  
  497. LAMER Exterminator
  498.  - This virus was sent to me by Andrew Mercer of the Palmerston North group.
  499. His letter said that He noticed strange things on his disks.  On
  500. disassembling the virus I found that most of it was encrypted and the data
  501. was encrypted randomly using the beam position of the screen.  Thus it
  502. appears different each time.  It patches the trackdisk.device to look at
  503. reads and writes, It patches the Sumkick vector in exec in case someone
  504. tries to get rid of it. When it detects a read or a write it will randomly
  505. select a sector on the disk and will check if it is a data block.  If it is
  506. it will write LAMER! all over the sector and rewrite it.  Some say this
  507. Virus will write to write protected disks.  I have not had this happen to me
  508. and I can see no special code in the disassembly to accomplish this feat.
  509.  
  510. TimeBomb Virus
  511.  - This is a strange Virus. It does not insert itself into any vectors.
  512. However it will copy itself back to the disk it came from.  When the
  513. count gets to 2 it will wipe out the Root Directory of the boot disk and
  514. display an alert.  If the count is over 2 it will just display an alert.
  515.  
  516. GADAFFI Virus
  517.  - Inserts itself into the CoolCapture vector, Uses a RomTag structure and
  518. patches the DoIO vector. Jumps directly into the Kickstart so will only work
  519. under V1.2 Kickstart. After 13 copies it will step the heads of drives 0
  520. and 1 in and out.  We simply clear all vectors and Use the old V1.2 DoIO
  521. code entry point.
  522.  
  523. BSG9 Virus 
  524. - This is similar to the IRQ virus in that it does not live in the Boot
  525. Block.  It operates differently.  Inserts itself into the RomTag pointer.
  526. It then loads the program it replaced and executes it.  On Reboot the RomTag
  527. is called.  It patches the Intuition OpenWindow Routine to its code.  It
  528. then returns.  Once AmigaDos opens up the CLI window the virus code gets
  529. run.  This gets the startup-sequence file and gets the first command that
  530. is run.  It then checks if it is already here. If not, then it moves this
  531. program from its directory into the devs:  directory and renames it a
  532. strange name.It then copies itself to replace the command it just moved.  A
  533. give away is the file size.  The Virus size is 2608 bytes and there will be
  534. a file with what looks like spaces for its name in the devs:  directory. To
  535. get rid of it we copy the file in devs:  back to the c: directory and rename
  536. it.Then delete the file in the devs:  directory.  In memory all we do is
  537. change the RT_INIT code which is run on reboot to do an immediate RTS. The
  538. memory for the program is still used but the Virus is disabled.  It will
  539. display a screen of its own which says:
  540.  A Computer Virus is a disease
  541.  Terrorism is a Transgression
  542.  Software Piracy is a crime
  543.  This is the Cure
  544.  BSG9 plus some other junk
  545.  
  546. War Hawks 
  547. - This Virus installs itself into the CoolCapture Vector.  It copies itself
  548. to the disk when the computer is warm booted.  After every four copies it
  549. displays a message.  To get rid of it we simply clear the CoolCapture vector.
  550.  
  551. VKill or Aids Virus  
  552.  - This is another virus hidden as a Virus protector.  When booted it copies
  553. itself to the stack area that is not used.  It then patches the CoolCapture
  554. vector to survive a reboot.  It patches the PutMsg vector of ExecBase to
  555. watch for BootBlock reads and writes.When it finds one it checks it and
  556. tells you if a virus is present.If you want to get rid of it it will copy
  557. itself to the disk.To remove it we Clear the CoolCapture Vector and
  558. SetFunction the PutMsg vector
  559.  
  560. Ultra Fox
  561.  - This one lives in the CoolCapture vector. When you reboot it will change
  562. the DoIO vector and wait for a BootBlock read.When it finds one and the disk
  563. is not already infected it will write itself to the bootblock.After every 16
  564. copies it will put a custom copper list which displays greetings.
  565.  
  566. PVLProtector
  567.  - This one is another bootblock protector.When it finds a virus it will
  568. write itself to the disk instead of a proper bootblock.  All we do is set
  569. the RomTag to do a RTS.
  570.  
  571. Revenge Lamer Exterminator (previously DOSSPEED)
  572.  
  573.  - This is another file virus.  It is supposed to speed up disk operations
  574. by 800%.  This was found on a BBS and when run patches itself into several
  575. places. It will read the s:startup-sequence file on reboot and will edit it
  576. so that it runs itself as the program. It sticks out because the first line
  577. in the startup-sequence will be blank.When the Checker finds it look in the
  578. Root directory and you will find what looks like a blank filename. Virus
  579. Checker will rename this virus for you. You can then delete the virus and
  580. alter your startup-sequence to get rid of the first blank line
  581.  
  582. UnKnown
  583.  - This is a virus that has no names anywhere and will only work under V1.2
  584. Kickstart.  Very easy to get rid of.
  585.  
  586. JITR Virus
  587.  - Very mild sort of virus this one.  Only writes itself to the BootBlock.
  588. Does nothing else.  Easily fixed by clearing the CoolCapture vector.
  589.  
  590. MicroSystems
  591.  - Haven't got this one yet so can't tell you much about it. Just have to
  592. restore a vector in the Exec.library and clear the Exec CoolCapture vector.
  593.  
  594. Xeno Virus
  595.  - This virus is a very nasty one in the way that it infects all programs
  596. that can be run. It does not need the program to be run but even someone
  597. doing a list or dir on a disk when the virus is present will infect all
  598. those other files on disk. It patches into the dos.library and takes over
  599. the OPEN,LOCK and LOADSEG calls in dos. This way it can intercept the files
  600. being looked at. It will copy itself to the start of every runnable program
  601. and alter the file so that it still works. There is also an encrypted
  602. message which says 'Greetings from the Xeno Virus' but I have not worked out
  603. when this appears yet. To get rid of it from memory we have to reset the
  604. changed vectors. To get rid of it from the file is very much harder. First
  605. the file has to have the virus removed from the code. Then the relocation
  606. data pointers have to be changed so that everything still works.
  607. When Virus_Checker finds a file infected with the Xeno Virus it will tell
  608. you which file it is and bring up a requester. You can now check the files
  609. on drive zero for further viruses if you want. I will soon add a string
  610. gadget so that all drives can be checked.
  611.  
  612. 16 Bit Crew
  613.  - This virus does not do much and only infects disks that you boot with.
  614. To get rid of it from memory we clear the CoolCapture Vector and restore
  615. the DoIO vector.
  616.  
  617. New Alien Beat Virus
  618.  - This one will only work under Version 1.2 Kickstart as it jumps into
  619. the ROM code directly. To fix in memory we have to manually patch the
  620. DoIO vector and FindResident Vector with the correct values for 1.2.
  621. and clear the Capture vectors.
  622.  
  623. BlackFlash virus
  624.  - This virus will display a message after a certain amount of copies of
  625. it have been made. It says that your computer is sick and has a virus. To
  626. remove it we just restore the DoIO vector and clear out the capture
  627. vectors.
  628.  
  629. Digital Emotions virus
  630.  - This is another tame virus. Only infects disks when it is rebooted.
  631. Clean out the Captures vectors and it is gone.
  632.  
  633. ScarFace Virus
  634.  - This takes over the BeginIO routine in the trackdisk.device to watch for
  635. reads and writes to the disk. When it finds one it will write itself to the
  636. disk. It also has a VertBlank interrupt which will do something after
  637. a while. I think it only reboots the machine. It also has a romtag which we
  638. have to clear out.
  639.  
  640. Turk Virus
  641.  - Another simple virus. Does not do very much. Simple to get rid of.
  642.  
  643. Joshua Virus
  644.  - Again, lives in the TrackDisk BeginIO and VertBlank Interrupt.
  645. Also has a RomTag to survive reboots. This one will display a sprite after
  646. so many interrupts. I am not sure what it looks like but maybe someone
  647. wants to wait until it is triggered. It counts interrupts. It will also
  648. infect every disk but in the drive that is not write protected. Data in it
  649. that says something is encoded. To remove we simply restore the BeginIO
  650. code and VertBlank Interrupt and wipe out the RomTag.
  651.  
  652. Butonic Virus
  653.  - This is another file type virus. It uses the DoIO vector to check for
  654. reads to the Root Block of a disk. It will then write the virus to the disk
  655. and add it to the startup-sequence as the first instruction. The filename
  656. of the virus and its comment make it invisible when doing a dir but shows
  657. up with a list. This will also bring up GURU messages and change the title
  658. of the active window to some german stuff.
  659. To get rid of it we clear the ROMTAG, restore the DoIO vector and delete
  660. the file off the disk. You will need to remove the blank line from the
  661. startup-sequence where the virus was.
  662. The second version of this infects the Level 2 Interrupt as well and uses
  663. different file names to hide itself in the startup-sequence.
  664.  
  665. Centurions Virus
  666.  - Another file type virus. It hooks into the Trackdisk BEGINIO vector and
  667. waits for reads to the boot block of a disk. It changes the SumKickData
  668. vector so that it will survive a checksum. To get rid of it in memory we
  669. simply kill the RomTag vector, restore the SumKickData vector and patch the
  670. trackdisk code it uses to skip over the virus.
  671. When it finds a read to the bootblock it will check the write protect. It
  672. will then find the startup-sequence and find the name of the first command.
  673. It then looks for the command in the root directory, then the c directory.
  674. Once found it adds itself to the front of the file and is run when the
  675. startup-sequence is run again. Signs of infection are that it adds 3916
  676. bytes to the size of the file it infects.
  677. After every ten copies it will change the pointer to a smiley face and a
  678. message will scroll across it.
  679.  
  680. Coders Nightmare Virus
  681.  - A boot block virus. Fairly tame this one but it will wreck copy
  682. protected disks. It takes over the DoIO vector waiting for reads to track
  683. zero block 0 then it writes itself to the disk if it can. It has a level 2
  684. interrupt which after a time will display a message and then reboot the
  685. machine. To remove we just reset the DoIO and Level 2 Interrupt vectors and
  686. clear out the RomTag.
  687.  
  688. Forpib Virus
  689.  - Another boot block virus. It takes over the Trackdisk BeginIO vector and
  690. waits for reads to block 0. Then it copies itself if it can. It also has a
  691. VertBlank Interrupt and after a certain time a message will appear. (I
  692. think). There is a bug in this in that it tries to use a color register but
  693. it has got the wrong value in there. To remove just restore both vectors
  694. and remove the RomTag.
  695.  
  696. GX Team virus
  697.  - Yet another bootblock virus. This just takes over the DoIO vector and
  698. after a certain number of copies it will bring up a requester then guru.
  699. To remove replace the DoIO vector and clear RomTag and Capture vectors.
  700. This virus will only work under version 1.2 kickstart.
  701.  
  702. Gremlins virus
  703. - Yes another bb virus. Sickening isn't it. Don't know what this one does but
  704. very easy to remove. Just zero the Capture vectors, restore the SumKickData
  705. vector and DoIO vector and it's gone.
  706.  
  707. Kauki virus
  708. - This boot block virus will only work under Version 1.2 kickstart. As I
  709. don't have it I can't tell you what is displayed but something is
  710. displayed. Easy to get rid of. Just clear the Capture vector and set the
  711. DoIO vector to $FC06DC just to make sure.
  712.  
  713.  
  714. Have given up Telling what BootBlock viruses do as they are mostly the same
  715. and all work the same way. From now on I will only give descriptions on File
  716. Type viruses.
  717.  
  718. SADDAM virus
  719. - This is a file type file that hides itself as the Disk-Validator. The
  720. disk on which it came was unvalidated so AmigaDOS loaded it to try and
  721. validate the disk. This causes the virus to run and infect your machine.
  722. It does infect a lot of vectors that need fixing when it is found.  I just
  723. wipe it off the disk and it is left to the user to put a new Disk-Validator
  724. on the disk.
  725. It will change the root block BitMap pointer so that if the virus is not
  726. running AmigaDOS will think the disk is UnValidated and load the virus.
  727. It will also change DATA blocks so DOS does not know them unless the virus
  728. is running. When the virus is triggered it will wipe out the whole disk and
  729. bring up a Requester telling you it is the SADDAm virus.
  730.  
  731. CCCP virus
  732. - This a combination Bootblock and file virus. It changes itself so that it
  733. will write to the BootBlock and to random files on the disk. The only way
  734. to find it on disk is to scan the whole disk.
  735.  
  736. Disaster Master 2
  737. - This is a fairly simple File type virus. It will write to a disk after a
  738. warm boot and if there is enough room on the disk will make a file called
  739. cls in the c directory and add cls * as the first line in the
  740. startup-sequence.
  741. We just clear the RomTag and Capture vectors, check the DoIO vector and
  742. that's it for memory. Just wipe the file off the disk and warn the User
  743. about the startup-sequence.
  744.  
  745. Hawnes virus
  746. - A simple file type virus. It infects the OpenLibrary vector waiting for an
  747. opening of intuition.library. It then patches OpenWindow to it's own
  748. routine. When a window opens it checks the startup-sequence and if not
  749. already present copies itself to the disk using DOS. It patched the VertB
  750. int and will display something after a while. It will Wipe out a disk after
  751. so many copies as well. Simple to remove and alter the first line in your
  752. startup-sequence which will hold in hex $C0A0E0A0C0.
  753.  
  754. Return Lamer virus
  755. - Another file type virus which replaces the Disk-Validator.It uses a
  756. RomTag to stay in memory, infects vectors, VertBlank Int, TrackDisk.device
  757. BeginIO, and another vector in the trackdisk. When the RomTag is called it
  758. infects the OpenWindow vector.
  759. Just delete the Disk-Validator and replace it from a good disk.
  760. In memory, just restore the vectors and clear the RomTag out.
  761.  
  762. Travelling Jack virus
  763. - A Link type virus this one installs itself into the internals of AmigaDOS
  764. taking over the BCPL inner workings. To check in memory we have to wind our
  765. way thru many vectors and then reinstall the original from the virus.
  766. To remove from file we just remove the first code hunk.
  767. Seems to copy itself to each file that has been read but not sure on this.
  768.  
  769. Liberator virus
  770. - This is a file virus that says it will remove all viruses but is in fact
  771. a virus itself.
  772. It copies itself to the s/startup-sequence with a line that says
  773. memcheck s
  774. You will also find a file called .FastDir on the disk.
  775. After a certain count it will delete the entire s/startup-sequence and
  776. display a message, stop access to the floppy drives and DH0:
  777. It will also stop most virus checking programs by RemTask()ing them.
  778. Virus_Checker 5.30 and above is safe from the current version as the Task
  779. name has been changed.
  780. Easy to remove, we just delete the file.
  781.